###############################################################################
#
# Tests for XlsxWriter.
#
# SPDX-License-Identifier: BSD-2-Clause
#
# Copyright (c), 2013-2025, John McNamara, jmcnamara@cpan.org
#

from xlsxwriter.workbook import Workbook

from ..excel_comparison_test import ExcelComparisonTest


class TestCompareXLSXFiles(ExcelComparisonTest):
    """
    Test file created by XlsxWriter against a file created by Excel.

    """

    def setUp(self):
        self.set_filename("types04.xlsx")

    def test_write_url_default(self):
        """Test writing hyperlinks with strings_to_urls on."""

        workbook = Workbook(self.got_filename)
        worksheet = workbook.add_worksheet()
        red = workbook.add_format({"font_color": "red"})

        worksheet.write(0, 0, "http://www.google.com/", red)
        worksheet.write_string(1, 0, "http://www.google.com/", red)

        workbook.close()

        self.assertExcelEqual()

    def test_write_url_implicit(self):
        """Test writing hyperlinks with strings_to_urls on."""

        workbook = Workbook(self.got_filename, {"strings_to_urls": True})
        worksheet = workbook.add_worksheet()
        red = workbook.add_format({"font_color": "red"})

        worksheet.write(0, 0, "http://www.google.com/", red)
        worksheet.write_string(1, 0, "http://www.google.com/", red)

        workbook.close()

        self.assertExcelEqual()

    def test_write_url_explicit(self):
        """Test writing hyperlinks with strings_to_urls off."""

        workbook = Workbook(self.got_filename, {"strings_to_urls": False})
        worksheet = workbook.add_worksheet()
        red = workbook.add_format({"font_color": "red"})

        worksheet.write_url(0, 0, "http://www.google.com/", red)
        worksheet.write(1, 0, "http://www.google.com/", red)

        workbook.close()

        self.assertExcelEqual()
